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SYSTEM AND METHOD FOR DEBUGGING 
MULTIPROCESSOR SYSTEMS 

TECHNICAL FIELD 

The system and method described herein relates generally to the field of computer 
systems, and more particularly, to debugging a computer system having multiple processors. 

BACKGROUND 

A personal computer system typically includes a system unit having a central 
processing unit (CPU) and associated memory, and a storage device such as a hard disk, 
floppy disk or CD ROM. Also included are an input device, such as a keyboard or mouse, a 
display device, and possibly other peripherals as well. Many computer systems today include 
multiple CPUs mounted on what is commonly referred to as a motherboard, wherein each of 
these CPUs contain code known as the system BIOS ("Basic Input/Output System"). The 
system BIOS is responsible for testing system hardware and starting the operating system 
during the booting process. The BIOS also contains data and instructions that enables the 
transfer of data to and from the system hardware. The system BIOS is stored in system 
memory, typically in non-volatile memory such as read-only memory (ROM) or flash 
memory. 

Before computer systems are sold, the BIOS must be "debugged," or tested to ensure 
that it is working properly, and if it is not then to ensure that any existing errors are detected 
and corrected. The motherboard of the computer typically includes a debug port provided for 
this purpose. A computer system having debugging software is connected to the motherboard 
via the debug port. The debug port is connected to each of the CPU sockets serially so that 
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5 signals and data flow serially from the debugging computer through the debug port, and then 
through each successive CPU before returning to the debugging computer through the debug 
port. 

Problems arise during debugging when one of the positions or slots on a motherboard 
designed to carry multiple CPUs is not occupied by a CPU. In some multiprocessor systems, 

10 an empty CPU slot must always be occupied to ensure proper termination of the line or bus 

T during normal operation of the computer. Separate terminator cards are inserted into the 
unoccupied CPU slots for this purpose. These terminator cards perform required termination 

Cn functions, and also, during debugging procedures, function to ensure that the signal is passed 
through to a subsequent CPU so as to properly complete the serial debugging circuit. An 

Jl"5 unoccupied CPU slot will otherwise cause a break in the debugging circuit, preventing 

V. altogether debugging of any CPU. Insertion of separate terminator cards in unoccupied slots 
is disadvantageous in that these separate terminator cards are expensive, and must be 
manually inserted during manufacturing. 

Some more recent multiprocessor systems do not need separate terminator cards to 

20 perform termination. These systems have termination capabilities built into the CPU that 
ensure termination. For purposes of debugging, however, empty CPU slots still must be 
bypassed to complete the debugging circuit path. For these types of systems, the only known 
method by which to bypass unpopulated CPU slots for debugging purposes is to insert a 
jumper between successive CPUs, and to manually adjust the jumper when undergoing 

25 debugging versus normal operation. Jumpers that require physical manipulation prior to 
debugging are both labor intensive and time consuming. Further, because of space 
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constraints it is becoming increasingly difficult to fit such jumpers between or in close 
proximity to the CPUs, as is required. 

Accordingly, what is needed is an improved system and method for debugging 
multiprocessor systems that may have unoccupied CPU slots. 



SUMMARY OF THE PREFERRED EMBODIMENTS 

In accordance with the present disclosure, a debugging circuit capable of debugging a 
plurality of possible microprocessors is provided that includes a debug port, a plurality of 
microprocessor sockets, each of which are adapted to receive a microprocessor, and a 
plurality of switches, each of which correspond to a respective one of the plurality of 
microprocessor sockets. The plurality of microprocessor sockets are adapted to form a serial 
signal path, and each of the switches is capable of automatically detecting whether a 
microprocessor is present in the corresponding microprocessor socket. If a microprocessor is 
present in the corresponding microprocessor socket, then said switch is automatically 
configured to include the microprocessor within the signal path, and if a microprocessor is 
not present in the corresponding microprocessor socket then the switch is automatically 
configured so that the signal path bypasses the corresponding microprocessor socket. 

According to one embodiment, a debugging input is provided to each microprocessor 
socket, and a debugging output is provided from each microprocessor that is present in the 
corresponding microprocessor socket. In yet another embodiment, each switch receives as an 
input a microprocessor detection signal indicating whether the corresponding microprocessor 
is present. 
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5 According to yet another embodiment, for each switch, if the microprocessor is 

present then the switch provides as an output the debugging output of the corresponding 
microprocessor. If the microprocessor is not present, then the switch provides as a switch 
output the debugging input to the corresponding microprocessor. 

In yet another embodiment, for each switch not corresponding to a last 
1 0 microprocessor in the serial signal path, the switch output is provided as a debugging input to 
" a subsequent microprocessor in the serial signal path. For the switch corresponding to the 
; last microprocessor in the serial signal path, the switch output is provided to the debug port. 

According to another embodiment, the debug port is electrically coupled to a 
computer and receives input from and provides output to said computer. 
15 According to yet alternate embodiments, the plurality of switches each comprise a 

pair of bipolar transistors or field effect transistors. 

A debugging switch is also provided for use in a debugging circuit capable of 
debugging a plurality of possible processors. The debugging switch includes a first node for 
receiving a processor detection signal indicating whether a first processor is present in a 
20 corresponding processor socket, a second node for receiving a debugging input signal to the 
first processor, a third node for receiving a debugging output signal from the first processor if 
the first processor is present in the corresponding processor socket, a fourth node for 
providing a switch output signal, and a switching element. If the processor detection signal 
indicates that the corresponding processor is not present, then the switching element is 
25 automatically configured so that the switch provides as a switch output the debugging input 
signal, and if the processor detection signal indicates that the corresponding processor is 
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present, then the switching element is automatically configured so that the switch provides as 
a switch output the debugging output signal. 

According to one embodiment, the switching element further comprises first and 
second bipolar transistors, and according to an alternate embodiment the switching element 
comprises field effect transistors. The field effect transistors may be junction field effect 
transistors or insulated gate field effect transistors. 

According to yet another embodiment, the switch output is provided as a debugging 
input to a second processor. 

A method for debugging at least one of a plurality of possible microprocessors is also 
provided including the step of providing a debugging circuit having a plurality of 
microprocessor sockets adapted to form a serial signal path. Each microprocessor socket 
corresponds to a different one of the plurality of possible microprocessors and is capable of 
receiving a microprocessor. The method further includes the steps of providing a switch 
corresponding to each of the microprocessor sockets, providing as an input to each of the 
switches a processor detection signal indicating whether a microprocessor is present in the 
corresponding microprocessor socket, providing as an input to each of the switches a 
processor debugging input for the corresponding microprocessor, and providing as an input to 
each of the switches a processor debugging output from the corresponding processor if the 
microprocessor is present in the corresponding microprocessor socket. The method further 
includes the step of the switch providing as a switch output the processor debugging input if 
the corresponding microprocessor is not present in the corresponding microprocessor socket, 
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and providing as a switch output the processor debugging output if the microprocessor is 
present in the corresponding microprocessor socket. 

According to one embodiment, the method further includes the step of, for each 
switch corresponding to a microprocessor that is not a last microprocessor in the serial signal 
path, providing the switch output as a debugging input to a subsequent microprocessor in the 
serial signal path. In yet another embodiment, the method further includes the step of, for the 
switch corresponding to the last microprocessor in the serial signal path, providing the switch 
output to a debug port. 

According to yet another embodiment, the method further includes the step of 
providing as a debugging input to a first microprocessor in the serial signal path a signal 
received from the debug port. 
BRIEF DESCRIPTION OF THE DRAWINGS 

A more complete understanding of the disclosed embodiments and advantages thereof 
may be acquired by referring to the following description taken in conjunction with the 
accompanying drawings, in which like reference numbers indicate like features, and wherein: 

FIGURE 1 illustrates a debugging circuit capable of debugging a plurality of possible 
microprocessors; and 

FIGURE 2 illustrates one embodiment of a switch for use in a debugging circuit 
capable of debugging a plurality of possible microprocessors. 
DETAILED DESCRIPTION 

Figure 1 illustrates a motherboard 100 of a computer system including multiple 
microprocessors (CPUs) 102a, 102b, 102c, and 102d, and a debug port 104. It is well known 
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that each of the microprocessors are received by a corresponding microprocessor "socket" 
located on the motherboard. The microprocessor sockets are not shown in Figure 1, as each 
such socket is occupied by a microprocessor. The debug port is a connector that enables an 
external computer system 106, when coupled with the debug port via cable 105 or the like, to 
utilize a debugging software program to communicate with the CPUs so as to monitor and/or 
control execution of BIOS code within each processor. A debugging circuit 110 passes 
signals from debug port 104 serially to each successive microprocessor socket before 
returning to the debug port. As will be described more fully below, the present invention 
automatically ensures that the serial debugging signal path is completed regardless of whether 
each of the possible CPUs are present in their corresponding microprocessor sockets. 

Switches 108a, 108b, 108c, 108d each correspond to a respective one of the 
microprocessor sockets, and each preferably is in parallel with its corresponding 
microprocessor socket. The switches each receive as an input a processor detection signal 
110a, 110b, 110c, HOd that indicates whether a microprocessor is present in the 
corresponding microprocessor socket. If present, the switch will automatically be configured 
to include that microprocessor within the debugging signal path, and if absent, the switch will 
automatically be configured so that the debugging signal path bypasses the unoccupied 
microprocessor socket. 

For example, in Figure 1, if the microprocessor detection signal 110c input to switch 
108c indicates that CPU2 is not present, switch 108c will be automatically configured to 
provide as a debugging input to CPU3, the signal 1 16b that would have otherwise have been 
provided as the debugging input to CPU2. Thus, switch 108c automatically ensures that the 
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5 debugging signal path is complete by bypassing the unoccupied microprocessor socket. If, 
however, CPU2 is present, switch 108c will be automatically configured to provide as a 
debugging input to CPU3 the debugging output signal from CPU2, thereby ensuring that 
CPU2 is included within the debugging signal path. 

Figure 2 illustrates one embodiment of such a switch in greater detail. For purposes 
0 of illustration, switch 108c is shown, although it will be understood that the illustrated circuit 
may be any of the switches shown in Figure 1. The debugging circuit receives a 
microprocessor detection signal 110c that indicates whether CPU2 is present at node 206, 
which is electrically coupled to the microprocessor socket that is capable of receiving CPU2. 
According to one embodiment in which the microprocessors are Intel processors, the CPU 
5 detection signal is a SKTOCC signal, which asserts a positive voltage on node 206 when 
CPU2 is not present, and is grounded when CPU2 is present. Switch 108c also includes 
another node 204 for receiving the microprocessor debugging output of CPU2 (112c), if the 
CPU is present in its corresponding socket. Switch 108c includes yet another node 202 for 
receiving the microprocessor debugging input to CPU2 (116b). For the Intel processors 
20 referred to above, the CPU2_TDI signal is the debugging input signal for CPU2 and 
CPU2_TDO is the debugging output signal for CPU2. Finally, the output of switch 108c 
provides the debugging input signal to CPU3 (1 16c) (i.e., CPU3_TDI) via node 212. 

The embodiment of Figure 2 further illustrates a typical pair of bipolar transistors 
arranged in a well known totem pole configuration so that, depending on the input at node 
25 206, one transistor will be turned on while the other is turned off. Thus, the signal path for 
the debugging circuit will either be from node 202 to node 212 so that the input to CPU2 
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5 (116b) will be directly provided as the input to CPU3, or from node 204 to node 212, so that 
output of CPU2 (112c) will be provided as the input to CPU3. In other words, the input 
(116b) to CPU2 will directly become the input to CPU3 (116c) if CPU2 is not present, 
thereby effectively bypassing CPU2. On the other hand, if CPU2 is present, the output to 
CPU2 (112c) will become the input to CPU3 (116c), ensuring that CPU2 is included within 
1 0 the signal path if present. 

" More specifically, for transistor 208, the application of a positive voltage (i.e., 3.3V) 

~ - at node 206, which in the Intel embodiment described indicates that CPU2 is not present, will 
~ - cause a positive voltage to be applied to the base of the transistor, which in turn will cause the 

current to flow from node 202 through the transistor to node 212. Thus, if CPU2 is not 
i 5 present, switch 108c transfers the input to CPU2 directly to the input to CPU3, bypassing the 

unoccupied CPU2 slot. For transistor 210, the application of a positive voltage at node 206 
~±Z turns off the transistor preventing current flow therethrough. If node 206 is grounded, 

however, such as is the case when CPU2 is present, then the application of this voltage level 

to the base of transistor 210 turns on the transistor, enabling current flow from node 204 to 
20 output node 212. When applied to the base of transistor 208, transistor 208 will be shut off, 

preventing current flow therethrough. Thus, when CPU2 is present, switch 108c conveys the 

debugging output from CPU2 directly as the debugging input for CPU3. 

Resistors 214 and 216 shown in Figure 2 are a well known pull up/pull down resistor 

pair used to ensure that the signal at node 212 is strong enough to maintain the integrity of the 
25 signal path. According to one embodiment, the voltage V+ applied at pull up resistor 214 is 

the CPU core voltage, which is typically anywhere below 2.2 volts. It will be understood by 
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5 those skilled in the art that the positive voltage applied at node 206, such as to indicate the 
absence of CPU2 as described above, must be sufficiently above the CPU core voltage to 
properly enable current flow through the transistors. Therefore, this voltage should be high 
enough to accommodate varying CPU core voltages. 

Further, although the embodiment of Figure 2 illustrates the use of bipolar type 

0 transistors, one skilled in the art will readily recognize that the circuit of switches 108 may be 
constructed using any type of field effect transistors, both junction and insulated gate. 

Although the present invention has been described in detail, it should be understood 
that various changes, substitutions and alterations can be made hereto without departing from 
the spirit and scope of the invention as defined by the appended claims. 
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WHAT IS CLAIMED IS : 

1 1. A debugging circuit capable of debugging a plurality of possible 

2 microprocessors, comprising: 

3 a debug port; 

4 a plurality of microprocessor sockets, each of said microprocessor sockets 

5 adapted to receive a microprocessor; 

6 a plurality of switches, each of said plurality of switches corresponding to a 

7 respective one of said plurality of microprocessor sockets; 

8 wherein said plurality of microprocessor sockets are adapted to form a serial 

9 signal path, and wherein each of said switches is capable of automatically detecting whether a 

10 microprocessor is present in the corresponding microprocessor socket, and if a 

11 microprocessor is present in said corresponding microprocessor socket then said switch is 

12 automatically configured to include said microprocessor within said signal path, and if a 

13 microprocessor is not present in said corresponding microprocessor socket then said switch is 

14 automatically configured so that said signal path bypasses said corresponding microprocessor 

15 socket. 



1 2. The debugging circuit according to claim 1, wherein a debugging input is 

2 provided to each microprocessor socket, and wherein a debugging output is provided from 

3 each microprocessor that is present in said corresponding microprocessor socket. 
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1 3. The debugging circuit according to claim 2, wherein each switch receives as 

2 an input a microprocessor detection signal indicating whether said corresponding 

3 microprocessor is present. 

1 4. The debugging circuit according to claim 3, wherein for each switch, if said 

2 microprocessor is present then said switch provides as an output said debugging output of 

3 said corresponding microprocessor. 

1 5. The debugging circuit according to claim 4, wherein for each switch, if said 

2 microprocessor is not present, then said switch provides as a switch output said debugging 

3 input to said corresponding microprocessor. 

1 6. The debugging circuit according to claim 5, wherein for each switch not 

2 corresponding to a last microprocessor in said serial signal path, said switch output is 

3 provided as a debugging input to a subsequent microprocessor in said serial signal path. 

1 7. The debugging circuit according to claim 6, wherein for said switch 

2 corresponding to said last microprocessor in said serial signal path, said switch output is 

3 provided to said debug port. 
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1 8. The debugging circuit according to claim 7, wherein said debug port is 

2 electrically coupled to a computer and receives input from and provides output to said 

3 computer. 



1 9. The debugging circuit according to claim 8, wherein said plurality of switches 

2 each comprise a pair of bipolar transistors. 



1 10. The debugging circuit according to claim 8, wherein said plurality of switches 

2 each comprise field effect transistors. 

1 11. A debugging switch for use in a debugging circuit capable of debugging a 

2 plurality of possible processors comprising: 

3 a first node for receiving a processor detection signal indicating whether a first 

4 processor is present in a corresponding processor socket; 

5 a second node for receiving a debugging input signal to said first processor; 

6 a third node for receiving a debugging output signal from said first processor 

7 if said first processor is present in said corresponding processor socket; 

8 a fourth node for providing a switch output signal; and 

9 a switching element, wherein if said processor detection signal indicates that 

10 said corresponding processor is not present, then said switching element is automatically 

1 1 configured so that said switch provides as a switch output said debugging input signal, and 

12 wherein if said processor detection signal indicates that said corresponding processor is 
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13 present, then said switching element is automatically configured so that said switch provides 

14 as a switch output said debugging output signal. 



1 12. The debugging switch according to claim 11, wherein said switching element 

2 further comprises first and second bipolar transistors. 

1 13. The debugging switch according to claim 12, wherein said switching element 

2 comprises field effect transistors. 

1 14. The debugging switch according to claim 13, wherein said field effect 

2 transistors are junction field effect transistors. 

1 15. The debugging switch according to claim 13, wherein said field effect 

2 transistors are insulated gate field effect transistors. 

1 16. The debugging switch according to claim 11, wherein said switch output is 

2 provided as a debugging input to a second processor. 

1 17. A method for debugging at least one of a plurality of possible 

2 microprocessors, comprising the steps of: 
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3 providing a debugging circuit having a plurality of microprocessor sockets adapted to 

4 form a serial signal path, wherein each microprocessor socket corresponds to a different one 

5 of said plurality of possible microprocessors and is capable of receiving a microprocessor; 

6 providing a switch corresponding to each of said microprocessor sockets; 

7 providing as an input to each of said switches a processor detection signal indicating 

8 whether a microprocessor is present in said corresponding microprocessor socket; 

9 providing as an input to each of said switches a processor debugging input for said 

10 corresponding microprocessor; 

1 1 providing as an input to each of said switches a processor debugging output from said 

12 corresponding processor if said microprocessor is present in said corresponding 

13 microprocessor socket; 

14 said switch providing as a switch output said processor debugging input if said 



15 corresponding microprocessor is not present in said corresponding microprocessor socket, 

1 6 and providing as a switch output said processor debugging output if said microprocessor is 

17 present in said corresponding microprocessor socket. 



1 18. The method according to claim 1 7, further comprising the step of: 

2 for each switch corresponding to a microprocessor that is not a last microprocessor in 

3 said serial signal path, providing said switch output as a debugging input to a subsequent 

4 microprocessor in said serial signal path. 

1 19. The method according to claim 1 8, further comprising the step of: 
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2 for said switch corresponding to said last microprocessor in said serial signal path, 

3 providing said switch output to a debug port. 

1 20. The method according to claim 19, further comprising the step of: 

2 providing as a debugging input to a first microprocessor in said serial signal path a 

3 signal received from said debug port. 

1 21 . The method according to claim 20, wherein said switches each comprise a pair 

2 of bipolar transistors. 

1 22. The method according to claim 20, wherein said switches each comprise field 

2 effect transistors. 
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SYSTEM AND METHOD FOR DEBUGGING 
MULTIPROCESSOR SYSTEMS 

ABSTRACT OF THE DISCLOSURE 

A debugging circuit capable of debugging a plurality of possible microprocessors, and 

a switch for use in the same. The debugging circuit includes a debugging port, a plurality of 

microprocessor sockets each adapted to receive a microprocessor, and a plurality of switches 

corresponding to a respective microprocessor socket. The plurality of microprocessor sockets 

are adapted to form a serial signal path, and each of the switches is capable of automatically 

detecting whether a microprocessor is present in the corresponding microprocessor socket. If 

a microprocessor is present, the switch is automatically configured to include the 

microprocessor within the signal path, and if the microprocessor is not present, the switch is 

automatically configured so that the signal path bypasses that microprocessor socket. 
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